<template>
    <div class="flex-col">
      <div class="flex-row justify-center" style="margin-bottom: 10px">
        <!-- 纸张大小 A3、A4 等 -->
        <div class="paper">
          <template v-for="(value, type) in paperTypes" :key="type">
            <button :class="curPaperType === type ? 'api' : 'info'" @click="setPaper(type, value)">
              {{ type }}
            </button>
          </template>

          <!-- 自定义纸张 -->
          <button :class="'other' == curPaperType ? 'api' : 'info'" class="auto" @click="showPaperPop">自定义纸张</button>
          <div class="popover">
            <div class="popover-content flex-col" v-show="paperPopVisible">
              <div style="font-size: 16px; font-weight: bold">设置纸张宽高(mm)</div>
                <div class="flex-row mt-10">
                  <input class="input" :value="paperWidth" type="number" placeholder="宽(mm)" />
                  <span class="ml-10 mr-10">x</span>
                  <input class="input" :value="paperHeight" type="number" placeholder="高(mm)" />
                </div>
              <button class="primary circle-10" style="margin-top: 6px" @click.stop="setPaperOther">确定</button>
            </div>
          </div>
        </div>

        <!-- 缩放 -->
        <div class="flex-row align-center ml-10">
          <button class="info circle-10" @click="changeScale(false)"><i class="iconfont sv-zoom-out" /></button>
          <div style="margin: 0 4px; width: 40px">{{ (scaleValue * 100).toFixed(0) }}%</div>
          <button class="info circle-10" @click="changeScale(true)"><i class="iconfont sv-zoom-in" /></button>
        </div>

        <button class="api circle-10 ml-10" @click.stop="saveStyle">
          <i class="iconfont sv-rotate" />
          保存样式
        </button>

        <!-- <button class="api circle-10 ml-10" @click.stop="rotatePaper">
          <i class="iconfont sv-rotate" />
          旋转纸张(宽高互换)
        </button> -->

        <button class="api circle-10 ml-10" @click.stop="clearPaper">
          <i class="iconfont sv-clear" />
          清空纸张
        </button>

        <!-- <button class="api circle-10 ml-10" @click.stop="exportJson">
          <i class="iconfont sv-export" />
          导出模板 json
        </button> -->
        <!-- <button class="api circle-10 ml-10" @click.stop="exportJsonTid">
          导出模板 json tid
          <i class="iconfont sv-export" />
        </button> -->

        <button class="secondary circle-10 ml-10" @click.stop="print">
          <i class="iconfont sv-printer" />
          浏览器打印
        </button>

        <button class="warning circle-10 ml-10" @click.stop="print2">
          直接打印(需要连接客户端)
          <i class="iconfont sv-printer" />
        </button>

        <button class="secondary circle-10 ml-10" @click="print">
          <i class="iconfont sv-printer" />
          生产条码
        </button>
        <button class="secondary circle-10 ml-10" @click.stop="GetSnNumber2">
          <i class="iconfont sv-printer" />
          出货条码
        </button>
        <button class="secondary circle-10 ml-10" @click.stop="GetSnNumber3">
          <i class="iconfont sv-printer" />
          镭射条码
        </button>

      </div>

      <div class="flex-row" style="height: 87vh">
        <div class="flex-2 left flex-col">
          <div class="title">默认样式</div>
          <!-- provider1 的容器; 加上 class "rect-printElement-types" 使用默认样式 -->
          <!-- 当然可以 重写 或者 自定义样式 -->
          <div id="provider-container1" class="container rect-printElement-types"></div>



          <div class="title">自定义样式</div>
          <!-- provider2 的容器; -->
          <!-- 这里自定义显示样式 custom-style-types -->
          <div id="provider-container2" class="container custom-style-types"></div>

          <div class="title">保存样例</div>
          <div>
            sss
          </div>


        </div>
        <div class="flex-5 center">
          <!-- 设计器的 容器 -->
          <div id="hiprint-printTemplate"></div>
        </div>
        <div class="flex-2 right">
          <!-- 元素参数的 容器 -->
          <div id="PrintElementOptionSetting"></div>
        </div>
      </div>
    </div>
</template>


<script setup name="条码打印">
import { onMounted, ref, getCurrentInstance } from "vue";
import { hiprint } from "vue-plugin-hiprint";
import { provider1 } from "./provider1";
import { provider2 } from "./provider2";
import template from "./template";
import printData from "./printData";

// 组合式函数 hooks
import { usePaper } from "../hooks/use-paper";
import { useZoom } from "../hooks/use-zoom";
// 工具
import { newHiprintPrintTemplate } from "../hooks/template-helper";
import request from '/@/utils/request';

const TEMPLATE_KEY = getCurrentInstance().type.name; // 存储模板对象的 key
const { paperTypes, curPaperType, paperPopVisible, paperWidth, paperHeight, showPaperPop, setPaper, setPaperOther } = usePaper(TEMPLATE_KEY);
const { scaleValue, changeScale } = useZoom(TEMPLATE_KEY);

// 自定义传入 provider 的参数
let options = {
  config: {
    tid: "providerModule1.config",
    title: "参数provider示例",
    type: "text",
    options: {
      testData: "单据表头",
      height: 30,
      fontSize: 16,
    },
  },
};


// 初始化 provider
hiprint.init({
  providers: [provider1(options), provider2(options)],
});
/**
 * 这里必须要在 onMounted 中去构建 左侧可拖拽元素 或者 设计器
 * 因为都是把元素挂载到对应容器中, 必须要先找到该容器
 */

let styles = []
let curStyle

onMounted(() => {
  buildLeftElement();

  //构建设计器
  buildDesigner();
  request({
        url: '/api/Record/PassStationRecord/GetModels',
        method: 'post',
        data: {
        }
    }).then(res=>{
      for(let i = 0; i < res.length; ++i) {
        styles.push(res[i])
      }
      if(res.length >0){
        hiprintTemplate.update(JSON.parse(res[0].Style))
        curStyle = res[0]
      }
    })
});

/**
 * 构建左侧可拖拽元素
 * 注意: 可拖拽元素必须在 hiprint.init() 之后调用
 * 调用之前 可以先 console.log($("#hiprint-printTemplate")) 看看是否有该 dom
 */
const buildLeftElement = () => {
  // ----- providerModule1 -----
  // eslint-disable-next-line no-undef
  $("#provider-container1").empty(); // 先清空, 避免重复构建
  // eslint-disable-next-line no-undef
  hiprint.PrintElementTypeManager.build($("#provider-container1"), "providerModule1");
  // ----- providerModule2 -----
  // eslint-disable-next-line no-undef
  $("#provider-container2").empty(); // 先清空, 避免重复构建
  // eslint-disable-next-line no-undef
  hiprint.PrintElementTypeManager.build($("#provider-container2"), "providerModule2");
};
/**
 * 构建设计器
 * 注意: 必须要在 onMounted 中去构建
 * 因为都是把元素挂载到对应容器中, 必须要先找到该容器
 */
let hiprintTemplate;
// ref 创建的模板json
const templateRef = ref(template);
console.log("templateRef 数据格式:");
console.log("templateRef", templateRef);
console.log("templateRef.value", templateRef.value);
const buildDesigner = () => {
  // eslint-disable-next-line no-undef
  $("#hiprint-printTemplate").empty(); // 先清空, 避免重复构建

  // 注意事项: 模板json(object)
  // 如果使用 vue ref创建的模板json, 需要使用 .value 获取 (确保内部能够使用 object.key 拿到对应数据就行)
  hiprintTemplate = newHiprintPrintTemplate(TEMPLATE_KEY, {
    template: templateRef.value, // 模板json(object)
    settingContainer: "#PrintElementOptionSetting", // 元素参数容器
  });
  // 构建 并填充到 容器中
  hiprintTemplate.design("#hiprint-printTemplate");
  console.log(hiprintTemplate);
};

/**
 * 浏览器打印
 */
const print = () => {
  // 参数: 打印时设置 左偏移量，上偏移量
  let options = { leftOffset: -1, topOffset: -1 };
  // 扩展
  let ext = {
    callback: () => {
      console.log("浏览器打印窗口已打开");
    },
    styleHandler: () => {
      // 重写 文本 打印样式
      return "<style>.hiprint-printElement-text{color:red !important;}</style>";
    },
  };
  // 调用浏览器打印
  hiprintTemplate.print({}, options, ext);
};

/**
 * 直接打印: 借助客户端,静默打印(无弹窗直接打印)
 * 注意: 需要先连接客户端
 */
const print2 = () => {
  if (hiprint.hiwebSocket.opened) {
    hiprintTemplate.print2(printData);
  } else {
    alert("请先连接客户端(刷新网页), 然后再点击「直接打印」");
  }
};


// ----------------- 模板对象 api 部分 -----------------
/**
 * 旋转纸张
 */

const saveStyle = async () => {

    await request({
        url: '/api/Record/PassStationRecord/SaveModel',
        method: 'post',
        data: {
            "Name": "11",
            "Style": JSON.stringify(hiprintTemplate.getJson()),
            "Length": 111,
            "Height": 111,
            // "Field1" = style.Field1,
            // "Field2" = style.Field2;
            // "Field3" = style.Field3;
        }
    }).then(res=>{
        if(res.Code == "0000") {
            alert("保存成功")
        } else{
            alert("保存失败");
            console.log(res.Mesg);
        }
    })
}

const rotatePaper = () => {
  hiprintTemplate.rotatePaper();
};

/**
 * 清空所有元素
 */
const clearPaper = () => {
  hiprintTemplate.clear();
};

/**
 * 导出模板 json
 * 必须确保 hiprintTemplate 已成功创建
 */
const exportJson = () => {
  let json = hiprintTemplate.getJson();
  console.log(json);
  alert("导出成功! 请查看控制台输出");
};

/**
 * 导出模板 json tid
 * 仅导出 options, 不导出 printElementType
 * 必须确保 hiprintTemplate 已成功创建
 */
  const exportJsonTid = () => {
  let json = hiprintTemplate.getJsonTid();
  console.log(json);
  alert("导出成功! 请查看控制台输出");
};

</script>






<style>
@import './style.css';

/* 重写默认的一个样式 */
.rect-printElement-types .hiprint-printElement-type > li > ul > li > a {
  color: red !important;
}

/* 自定义 provider 构建样式 */
.custom-style-types .hiprint-printElement-type {
  display: block;
}
.custom-style-types .hiprint-printElement-type {
  padding: 0 0 0 0;
  list-style: none;
}
.custom-style-types .hiprint-printElement-type > li > .title {
  display: block;
  padding: 4px 0px;
  color: rgb(0, 58, 230);
  clear: both;
}
.custom-style-types .hiprint-printElement-type > li > ul {
  padding: 0 0 0 0;
  display: block;
  list-style: none;
}
.custom-style-types .hiprint-printElement-type > li > ul > li {
  display: block;
  width: 50%;
  float: left;
  max-width: 100px;
}
.custom-style-types .hiprint-printElement-type > li > ul > li > a {
  padding: 12px 6px;
  color: #1296db;
  text-decoration: none;
  background: #fff;
  border: 1px solid #ddd;
  margin-right: 5px;
  width: 95%;
  max-width: 100px;
  display: inline-block;
  text-align: center;
  margin-bottom: 7px;
  box-sizing: border-box;
  border: 1px solid rgba(0, 0, 0, 0.2);
  border-radius: 4px;
  box-shadow: 0 1px 0 0 rgba(0, 0, 0, 0.15);
}
</style>

<style scoped>
/* api按钮 */
.api {
  background: #00acc1;
}
.auto {
  width: auto !important;
}
/* 纸张 */
.paper {
  margin-right: 10px;
}
.paper button:not(class*="auto") {
  width: 60px !important;
}
/* 多个 button 间距 */
.paper button + button {
  margin-left: -1px;
}
.paper button:first-child:last-child {
  border-radius: 4px;
}
/* 两边的 btn 圆角 */
.paper button:first-child:not(:last-child) {
  border-top-left-radius: 4px;
  border-bottom-left-radius: 4px;
}
.paper button:last-child:not(:first-child) {
  border-top-right-radius: 4px;
  border-bottom-right-radius: 4px;
}
.popover {
  position: absolute;
  margin-top: 10px;
  z-index: 10;
}
.popover .popover-content {
  background: white;
  border-radius: 4px;
  padding: 10px 14px;
  box-shadow: 2px 2px 2px 4px rgb(128 0 128 / 20%);
}
.popover .input {
  height: 24px;
  padding: 2px 4px;
}
.popover .input:hover {
  border-color: rgb(245, 155, 241);
  border-radius: 4px;
}

/* 区域 */
.left {
  background: white;
  border-radius: 4px;
  border: 1px solid #d9d9d9;
  box-shadow: 2px 2px 2px 0px rgb(128 0 128 / 20%);
  overflow: auto;
}
.left .container {
  height: 50%;
  overflow: auto;
  padding: 0 10%;
  background: lightblue;
}
.left .container[id*="provider-container2"] {
  margin-bottom: 10px;
  background: lightgray;
}
.center {
  margin: 0 10px;
  background: white;
  border-radius: 4px;
  border: 1px solid #d9d9d9;
  padding: 20px;
  box-shadow: 2px 2px 2px 0px rgb(128 0 128 / 20%);
  overflow: auto;
}
.right {
  background: white;
  border-radius: 4px;
  border: 1px solid #d9d9d9;
  padding: 10px 0;
  box-shadow: 2px 2px 2px 0px rgb(128 0 128 / 20%);
  overflow: auto;
}
/* 左侧拖拽元素样式 */
.title {
  font-size: 16px;
  font-weight: 500;
  margin: 4px 0 4px 10px;
}
.item {
  display: flex;
  flex-direction: column;
  align-items: center;
  background: white;
  padding: 4px 10px;
  margin: 10px 8px 4px 8px;
  width: 38%;
  min-height: 60px;
  border-radius: 4px;
  box-shadow: 2px 2px 2px 2px rgba(171, 171, 171, 0.2);
}
.item .iconfont {
  font-size: 1.5rem;
}
.item span {
  font-size: 14px;
}
</style>
